//
//  WBWelcomeView.swift
//  Weibo
//
//  Created by cc on 10/12/17.
//  Copyright © 2017 cc. All rights reserved.
//

import UIKit
import SDWebImage


/// 欢迎视图
class WBWelcomeView: UIView {

    @IBOutlet weak var iconView: UIImageView!
    @IBOutlet weak var tipLabel: UILabel!
    @IBOutlet weak var bottomCons: NSLayoutConstraint!
    @IBOutlet weak var iconWidthCons: NSLayoutConstraint!
    
    
    
    @objc class func welcomeView() -> WBWelcomeView {
        let nib = UINib(nibName: "WBWelcomeView", bundle: nil)
        
        let v = nib.instantiate(withOwner: nil, options: nil)[0] as! WBWelcomeView
        
        //从xib 加载的视图，默认的600 * 600
        v.frame = UIScreen.main.bounds
        
        return v
    }
    
    required init?(coder aDecoder: NSCoder) {
        super.init(coder: aDecoder)
        
        //提示： initWithCode 只是刚刚从xib的二进制文件将视图数据加载完成
        //还没有和代码连线建立起关系， 不要在这个方法中处理UI
        print("initwithCode + \(iconView)")
        
    }
    
    
    
    /// 从xib完成加载调用
    override func awakeFromNib() {
        //1. url
        guard let urlString = WBNetworkManager.shared.userAccount.avatar_large,
            let url = URL(string: urlString) else {
            return
        }
        
        //2.设置头像  - 如果网络图像没有下载完成， 先显示占位图像
        //如果不指定，之前设置的图像会被清空
        iconView.sd_setImage(with: url, placeholderImage: UIImage(named: "avatar_default_big"))
        
        
        //3.设置圆角(iconView的bounds 还没设置)
//        iconView.layer.cornerRadius = iconView.bounds.width * 0.5
        iconView.layer.cornerRadius = iconWidthCons.constant * 0.5
        iconView.layer.masksToBounds = true
        
    }
    
    
    //自动布局系统更新完成约束，会自动调用此方法
    //通常是对子视图布局进行修改
//    override func layoutSubviews() {
//
//    }
    
    
    /// 视图被添加到window上,表示视图已经显示
    override func didMoveToWindow() {
        super.didMoveToWindow()
        
        //视图是使用自动布局来设置的，只是设置了约束
        //- 当视图被添加到window上时，根据父视图的大小，计算约束值，更新控件位置
        //- layoutIfNeeded会直接按照当前的约束直接更新控件的位置
        //- 执行之后，控件所在的位置，就是xib中布局的位置
        self.layoutIfNeeded()
        
        bottomCons.constant = bounds.size.height - 200
        
        //如果控件们的frame没有计算好，所有的约束会一起动画
        UIView.animate(withDuration: 1.0, delay: 0, usingSpringWithDamping: 0.7, initialSpringVelocity: 0, options: [], animations: {
            //更新约束
            self.layoutIfNeeded()
        }) { (_) in
            UIView.animate(withDuration: 1.0, animations: {
                self.tipLabel.alpha = 1
            }, completion: { (_) in
                self.removeFromSuperview()
            })
        }
    }
    
}
